<!DOCTYPE html>
<html>
<head><meta name="generator" content="Hexo 3.8.0">
  <meta charset="utf-8">

  <!-- PACE Progress Bar START -->
  
    <script src="https://raw.githubusercontent.com/HubSpot/pace/v1.0.2/pace.min.js"></script>
    <link rel="stylesheet" href="https://github.com/HubSpot/pace/raw/master/themes/orange/pace-theme-flash.css">
  
  

  <!-- PACE Progress Bar START -->

  
  <title>vim常用快捷键大全 | FunGa技术札记</title>
  <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
  
  <meta name="keywords" content="vim">
  
  
  
  
  <meta name="description" content="摘要，显示在首页">
<meta name="keywords" content="vim">
<meta property="og:type" content="article">
<meta property="og:title" content="vim常用快捷键大全">
<meta property="og:url" content="funga.cn/2017/12/20/vim-cmd/index.html">
<meta property="og:site_name" content="FunGa技术札记">
<meta property="og:description" content="摘要，显示在首页">
<meta property="og:locale" content="default">
<meta property="og:image" content="http://funga.oss-cn-beijing.aliyuncs.com/images/vim.jpg">
<meta property="og:updated_time" content="2019-01-05T07:52:57.286Z">
<meta name="twitter:card" content="summary">
<meta name="twitter:title" content="vim常用快捷键大全">
<meta name="twitter:description" content="摘要，显示在首页">
<meta name="twitter:image" content="http://funga.oss-cn-beijing.aliyuncs.com/images/vim.jpg">
  
    <link rel="alternate" href="/atom.xml" title="FunGa技术札记" type="application/atom+xml">
  
  <link rel="icon" href="/css/images/favicon.ico">
  
  <link href="https://fonts.googleapis.com/css?family=Open+Sans|Montserrat:700" rel="stylesheet" type="text/css">
  <link href="https://fonts.googleapis.com/css?family=Roboto:400,300,300italic,400italic" rel="stylesheet" type="text/css">
  <link href="https://cdn.bootcss.com/font-awesome/4.6.3/css/font-awesome.min.css" rel="stylesheet">
  <style type="text/css">
    @font-face{font-family:futura-pt;src:url(https://use.typekit.net/af/9749f0/00000000000000000001008f/27/l?subset_id=2&fvd=n5) format("woff2");font-weight:500;font-style:normal;}
    @font-face{font-family:futura-pt;src:url(https://use.typekit.net/af/90cf9f/000000000000000000010091/27/l?subset_id=2&fvd=n7) format("woff2");font-weight:500;font-style:normal;}
    @font-face{font-family:futura-pt;src:url(https://use.typekit.net/af/8a5494/000000000000000000013365/27/l?subset_id=2&fvd=n4) format("woff2");font-weight:lighter;font-style:normal;}
    @font-face{font-family:futura-pt;src:url(https://use.typekit.net/af/d337d8/000000000000000000010095/27/l?subset_id=2&fvd=i4) format("woff2");font-weight:400;font-style:italic;}</style>
    
  <link rel="stylesheet" id="athemes-headings-fonts-css" href="//fonts.googleapis.com/css?family=Yanone+Kaffeesatz%3A200%2C300%2C400%2C700&amp;ver=4.6.1" type="text/css" media="all">
  <link rel="stylesheet" href="/css/style.css">

  <script src="https://code.jquery.com/jquery-3.1.1.min.js"></script>

  <!-- Bootstrap core CSS -->
  <link rel="stylesheet" href="https://netdna.bootstrapcdn.com/bootstrap/3.0.2/css/bootstrap.min.css">
  <link rel="stylesheet" href="/css/hiero.css">
  <link rel="stylesheet" href="/css/glyphs.css">
  
    <link rel="stylesheet" href="/css/vdonate.css">
  

  <!-- Custom CSS -->
  <link rel="stylesheet" href="/css/my.css">
  <!-- Google Adsense -->
  
<link rel="stylesheet" href="/css/prism-tomorrow.css" type="text/css"></head>
</html>
<script>
var themeMenus = {};

  themeMenus["/"] = "Home"; 

  themeMenus["/archives"] = "Archives"; 

  themeMenus["/categories"] = "Categories"; 

  themeMenus["/tags"] = "Tags"; 

  themeMenus["/about"] = "About"; 

</script>


  <body data-spy="scroll" data-target="#toc" data-offset="50">


  <header id="allheader" class="site-header" role="banner">
  <div class="clearfix container">
      <div class="site-branding">

          <h1 class="site-title">
            
              <a href="/" title="FunGa技术札记" rel="home"> FunGa技术札记 </a>
            
          </h1>

          
            
          <nav id="main-navigation" class="main-navigation" role="navigation">
            <a class="nav-open">Menu</a>
            <a class="nav-close">Close</a>
            <div class="clearfix sf-menu">

              <ul id="main-nav" class="nmenu sf-js-enabled">
                    
                      <li class="menu-item menu-item-type-custom menu-item-object-custom menu-item-home menu-item-1663"> <a class="" href="/">Home</a> </li>
                    
                      <li class="menu-item menu-item-type-custom menu-item-object-custom menu-item-home menu-item-1663"> <a class="" href="/archives">Archives</a> </li>
                    
                      <li class="menu-item menu-item-type-custom menu-item-object-custom menu-item-home menu-item-1663"> <a class="" href="/categories">Categories</a> </li>
                    
                      <li class="menu-item menu-item-type-custom menu-item-object-custom menu-item-home menu-item-1663"> <a class="" href="/tags">Tags</a> </li>
                    
                      <li class="menu-item menu-item-type-custom menu-item-object-custom menu-item-home menu-item-1663"> <a class="" href="/about">About</a> </li>
                    
              </ul>
            </div>
          </nav>


      </div>
  </div>
</header>




  <div id="container">
    <div id="wrap">
            
      <div id="content" class="outer">
        
          <section id="main" style="float:none;"><article id="post-vim-cmd" style="width: 66%; float:left;" class="article article-type-post" itemscope="" itemprop="blogPost">
  <div id="articleInner" class="clearfix post-1016 post type-post status-publish format-standard has-post-thumbnail hentry category-template-2 category-uncategorized tag-codex tag-edge-case tag-featured-image tag-image tag-template">
    
<div class="article-gallery">
  <div class="article-gallery-photos">
    
      <a class="article-gallery-img fancybox" href="http://funga.oss-cn-beijing.aliyuncs.com/images/vim.jpg" rel="gallery_cjqujn6wu00108zvno92gqp8h">
        <img src="http://funga.oss-cn-beijing.aliyuncs.com/images/vim.jpg" itemprop="image">
      </a>
    
  </div>
</div>

    
      <header class="article-header">
        
  
    <h1 class="thumb" itemprop="name">
      vim常用快捷键大全
    </h1>
  

      </header>
    
    <div class="article-meta">
      
	Posted on <a href="/2017/12/20/vim-cmd/" class="article-date">
	  <time datetime="2017-12-20T08:49:39.000Z" itemprop="datePublished">December 20, 2017</time>
	</a>

      
	<span id="busuanzi_container_page_pv">
	  本文总阅读量<span id="busuanzi_value_page_pv"></span>次
	</span>

    </div>
    <div class="article-entry" itemprop="articleBody">
      
        <blockquote>
<p>据说部分人会使用vim来当IDE用，这个我没试过，但是在linux平台，使用vim编辑一些配置文件是几乎每天干的事情，所以掌握vim的使用也是一位合格程序员必备技能。</p>
</blockquote>
<a id="more"></a>
<h2 id="模式"><a href="#模式" class="headerlink" title="模式"></a>模式</h2><ul>
<li>正常模式：可以使用快捷键命令，或按:输入命令行。</li>
<li>插入模式：可以输入文本，在正常模式下，按i、a、o等都可以进入插入模式。</li>
<li>可视模式：正常模式下按v可以进入可视模式， 在可视模式下，移动光标可以选择文本。按V进入可视行模式， 总是整行整行的选中。ctrl+v进入可视块模式。</li>
<li>替换模式：正常模式下，按R进入。</li>
</ul>
<h2 id="启动vim"><a href="#启动vim" class="headerlink" title="启动vim"></a>启动vim</h2><ul>
<li><p><code>vim -c cmd file</code>: 在打开文件前，先执行指定的命令；</p>
</li>
<li><p><code>vim -r file</code>: 恢复上次异常退出的文件；</p>
</li>
<li><p><code>vim -R file</code>: 以只读的方式打开文件，但可以强制保存；</p>
</li>
<li><p><code>vim -M file</code>: 以只读的方式打开文件，不可以强制保存；</p>
</li>
<li><p><code>vim -y num file</code>: 将编辑窗口的大小设为num行；</p>
</li>
<li><p><code>vim + file</code>: 从文件的末尾开始；</p>
</li>
<li><p><code>vim +num file</code>: 从第num行开始；</p>
</li>
<li><p><code>vim +/string file</code>: 打开file，并将光标停留在第一个找到的string上。</p>
</li>
<li><p><code>vim --remote file</code>: 用已有的vim进程打开指定的文件。 如果你不想启用多个vim会话，这个很有用。但要注意， 如果你用vim，会寻找名叫VIM的服务器；如果你已经有一个gvim在运行了， 你可以用<code>gvim --remote file</code>在已有的gvim中打开文件。</p>
</li>
</ul>
<h2 id="文档操作"><a href="#文档操作" class="headerlink" title="文档操作"></a>文档操作</h2><ul>
<li><code>:e</code> – 重新加载当前文档。</li>
<li><code>:e!</code> – 重新加载当前文档，并丢弃已做的改动。</li>
<li><code>:e#</code>或<code>ctrl+^</code> – 回到刚才编辑的文件，很实用。</li>
<li><code>:f</code>或<code>ctrl+g</code> – 显示文档名，是否修改，和光标位置。</li>
<li><code>:f filename</code> – 改变编辑的文件名，这时再保存相当于另存为。</li>
<li><code>gf</code> – 打开以光标所在字符串为文件名的文件。</li>
<li><code>:w</code> – 保存修改。</li>
<li><code>:wq</code> – 保存并退出。</li>
<li><code>ZZ</code> – 保存并退出。</li>
<li><code>:x</code> – 保存并退出。</li>
<li><code>:q[uit]</code> ——退出当前窗口。(<code>CTRL-W q</code>或<code>CTRL-W CTRL-Q</code>)</li>
<li><code>:saveas newfilename</code> – 另存为</li>
</ul>
<h2 id="光标移动"><a href="#光标移动" class="headerlink" title="光标移动"></a>光标移动</h2><h3 id="基本移动"><a href="#基本移动" class="headerlink" title="基本移动"></a>基本移动</h3><ul>
<li><code>w:</code> 前移一个单词，光标停在下一个单词开头；</li>
<li><code>W:</code> 移动下一个单词开头，但忽略一些标点；</li>
<li><code>e:</code> 前移一个单词，光标停在下一个单词末尾；</li>
<li><code>E:</code> 移动到下一个单词末尾，如果词尾有标点，则移动到标点；</li>
<li><code>b:</code> 后移一个单词，光标停在上一个单词开头；</li>
<li><code>B:</code> 移动到上一个单词开头，忽略一些标点；</li>
<li><p><code>ge:</code> 后移一个单词，光标停在上一个单词末尾；</p>
</li>
<li><p><code>0:</code> 移动到行首。</p>
</li>
<li><code>g0:</code> 移到光标所在屏幕行行首。</li>
<li><code>^:</code> 移动到本行第一个非空白字符。</li>
<li><code>g^</code>: 同 ^ ，但是移动到当前屏幕行第一个非空字符处。</li>
<li><code>$</code>: 移动到行尾。</li>
<li><code>g$</code>: 移动光标所在屏幕行行尾。</li>
<li><code>n|</code>: 把光标移到递n列上。</li>
<li><code>nG</code>: 到文件第n行。</li>
<li><code>:n&lt;cr&gt;</code> 移动到第n行。</li>
<li><code>:$&lt;cr&gt;</code> 移动到最后一行。</li>
<li><code>H:</code> 把光标移到屏幕最顶端一行。</li>
<li><code>M:</code> 把光标移到屏幕中间一行。</li>
<li><code>L:</code> 把光标移到屏幕最底端一行。</li>
<li><code>gg:</code> 到文件头部。</li>
<li><code>G:</code> 到文件尾部。</li>
</ul>
<h3 id="翻屏"><a href="#翻屏" class="headerlink" title="翻屏"></a>翻屏</h3><ul>
<li><code>ctrl+f</code>: 下翻一屏。</li>
<li><code>ctrl+b</code>: 上翻一屏。</li>
<li><code>ctrl+d</code>: 下翻半屏。</li>
<li><code>ctrl+u</code>: 上翻半屏。</li>
<li><code>ctrl+e</code>: 向下滚动一行。</li>
<li><code>ctrl+y</code>: 向上滚动一行。</li>
<li><code>n%</code>: 到文件n%的位置。</li>
<li><code>zz</code>: 将当前行移动到屏幕中央。</li>
<li><code>zt</code>: 将当前行移动到屏幕顶端。</li>
<li><code>zb</code>: 将当前行移动到屏幕底端。</li>
</ul>
<h2 id="文本插入"><a href="#文本插入" class="headerlink" title="文本插入"></a>文本插入</h2><ul>
<li><code>i</code>: 在光标前插入；一个小技巧：按8，再按i，进入插入模式，输入=， 按esc进入命令模式，就会出现8个=。 这在插入分割线时非常有用，如30i+<esc>就插入了36个+组成的分割线。</esc></li>
<li><code>I</code>: 在当前行第一个非空字符前插入；</li>
<li><code>gI</code>: 在当前行第一列插入；</li>
<li><code>a</code>: 在光标后插入；</li>
<li><code>A</code>: 在当前行最后插入；</li>
<li><code>o</code>: 在下面新建一行插入；</li>
<li><code>O</code>: 在上面新建一行插入；</li>
<li><code>:r</code> filename在当前位置插入另一个文件的内容。</li>
<li><code>:[n]r filename</code>在第n行插入另一个文件的内容。</li>
<li><code>:r !date</code> 在光标处插入当前日期与时间。同理，:r !command可以将其它shell命令的输出插入当前文档。</li>
</ul>
<h2 id="查找"><a href="#查找" class="headerlink" title="查找"></a>查找</h2><ul>
<li><code>/something</code>: 在后面的文本中查找something。</li>
<li><code>?something</code>: 在前面的文本中查找something。</li>
<li><code>/pattern/+number</code>: 将光标停在包含pattern的行后面第number行上。</li>
<li><code>/pattern/-number</code>: 将光标停在包含pattern的行前面第number行上。</li>
<li><code>n</code>: 向后查找下一个。</li>
<li><code>N</code>: 向前查找下一个。</li>
</ul>

      
    </div>
    <footer class="entry-meta entry-footer">
      
	<span class="ico-folder"></span>
    <a class="article-category-link" href="/categories/其它分类/">其它分类</a>

      
  <span class="ico-tags"></span>
  <ul class="article-tag-list"><li class="article-tag-list-item"><a class="article-tag-list-link" href="/tags/vim/">vim</a></li></ul>

      
        <div id="donation_div"></div>

<script src="/js/vdonate.js"></script>
<script>
var a = new Donate({
  title: '如果觉得我的文章对您有用，请随意打赏。您的支持将鼓励我继续创作!', // 可选参数，打赏标题
  btnText: 'Donate', // 可选参数，打赏按钮文字
  el: document.getElementById('donation_div'),
  wechatImage: 'https://funga.oss-cn-beijing.aliyuncs.com/config/wechat_pay_code.jpg',
  alipayImage: 'https://funga.oss-cn-beijing.aliyuncs.com/config/alipay_code.png'
});
</script>
      
            
      
        <!--PC版-->
<div id="SOHUCS"></div>
<!-- <script charset="utf-8" type="text/javascript" src="https://changyan.sohu.com/upload/changyan.js" ></script> -->
<script charset="utf-8" type="text/javascript" src="https://funga.oss-cn-beijing.aliyuncs.com/static/changyan.js"></script>
<script type="text/javascript">
window.changyan.api.config({
appid: 'cyrV0wIGI',
conf: 'prod_3d29a99dcddb3782e98f1fa951b9868f'
});
</script>
      
    </footer>
  </div>
  
    
<nav id="article-nav">
  
    <a href="/2017/12/25/sb-prj/" id="article-nav-newer" class="article-nav-link-wrap">
      <strong class="article-nav-caption">Newer</strong>
      <div class="article-nav-title">
        
          创建SpringBoot工程
        
      </div>
    </a>
  
  
    <a href="/2017/12/17/docker-cmd/" id="article-nav-older" class="article-nav-link-wrap">
      <strong class="article-nav-caption">Older</strong>
      <div class="article-nav-title">Docker常用命令大全</div>
    </a>
  
</nav>

  
</article>

<!-- Table of Contents -->

  <aside id="sidebar">
    <div id="toc" class="toc-article" style="overflow-y: scroll; max-width: 28%;">
    <strong class="toc-title">Contents</strong>
    
      <ol class="nav"><li class="nav-item nav-level-2"><a class="nav-link" href="#模式"><span class="nav-number">1.</span> <span class="nav-text">模式</span></a></li><li class="nav-item nav-level-2"><a class="nav-link" href="#启动vim"><span class="nav-number">2.</span> <span class="nav-text">启动vim</span></a></li><li class="nav-item nav-level-2"><a class="nav-link" href="#文档操作"><span class="nav-number">3.</span> <span class="nav-text">文档操作</span></a></li><li class="nav-item nav-level-2"><a class="nav-link" href="#光标移动"><span class="nav-number">4.</span> <span class="nav-text">光标移动</span></a><ol class="nav-child"><li class="nav-item nav-level-3"><a class="nav-link" href="#基本移动"><span class="nav-number">4.1.</span> <span class="nav-text">基本移动</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#翻屏"><span class="nav-number">4.2.</span> <span class="nav-text">翻屏</span></a></li></ol></li><li class="nav-item nav-level-2"><a class="nav-link" href="#文本插入"><span class="nav-number">5.</span> <span class="nav-text">文本插入</span></a></li><li class="nav-item nav-level-2"><a class="nav-link" href="#查找"><span class="nav-number">6.</span> <span class="nav-text">查找</span></a></li></ol>
    
    </div>
  </aside>
</section>
        
      </div>
      <footer id="footer" class="site-footer">
  

  <div class="clearfix container">
      <div class="site-info">
	      &copy; 2019 FunGa技术札记 All Rights Reserved.
          
            <span id="busuanzi_container_site_uv">
              本站访客数<span id="busuanzi_value_site_uv"></span>人次  
              本站总访问量<span id="busuanzi_value_site_pv"></span>次
            </span>
          
      </div>
      <div class="site-credit">
        Theme by <a href="https://github.com/iTimeTraveler/hexo-theme-hiero" target="_blank">hiero</a>
      </div>
  </div>
</footer>


<!-- min height -->

<script>
    var contentdiv = document.getElementById("content");

    contentdiv.style.minHeight = document.body.offsetHeight - document.getElementById("allheader").offsetHeight - document.getElementById("footer").offsetHeight + "px";
</script>

<!-- Custome JS -->
<script src="/js/my.js"></script>
    </div>
    <!-- <nav id="mobile-nav">
  
    <a href="/" class="mobile-nav-link">Home</a>
  
    <a href="/archives" class="mobile-nav-link">Archives</a>
  
    <a href="/categories" class="mobile-nav-link">Categories</a>
  
    <a href="/tags" class="mobile-nav-link">Tags</a>
  
    <a href="/about" class="mobile-nav-link">About</a>
  
</nav> -->
    

<!-- mathjax config similar to math.stackexchange -->

<script type="text/x-mathjax-config">
  MathJax.Hub.Config({
    tex2jax: {
      inlineMath: [ ['$','$'], ["\\(","\\)"] ],
      processEscapes: true
    }
  });
</script>

<script type="text/x-mathjax-config">
    MathJax.Hub.Config({
      tex2jax: {
        skipTags: ['script', 'noscript', 'style', 'textarea', 'pre', 'code']
      }
    });
</script>

<script type="text/x-mathjax-config">
    MathJax.Hub.Queue(function() {
        var all = MathJax.Hub.getAllJax(), i;
        for(i=0; i < all.length; i += 1) {
            all[i].SourceElement().parentNode.className += ' has-jax';
        }
    });
</script>

<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.4/MathJax.js?config=TeX-AMS-MML_HTMLorMML">
</script>



  <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/fancybox/2.1.5/jquery.fancybox.min.css">
  <script src="https://cdnjs.cloudflare.com/ajax/libs/fancybox/2.1.5/jquery.fancybox.min.js"></script>


<script src="/js/scripts.js"></script>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
<script src="/js/main.js"></script>







  <div style="display: none;">
    <script src="https://s95.cnzz.com/z_stat.php?id=1260716016&web_id=1260716016" language="JavaScript"></script>
  </div>



	<script async src="https://dnqof95d40fo6.cloudfront.net/atw7f8.js">
	</script>






  </div>

  <a id="rocket" href="#top" class=""></a>
  <script type="text/javascript" src="/js/totop.js" async=""></script>
</body>
</html>
